package com.slofzx.nuoda.evaluation.project.service;

import com.slofzx.nuoda.evaluation.project.dto.PlanInfoDTO;
import com.slofzx.nuoda.evaluation.project.dto.ProjectInfoDTO;
import com.slofzx.nuoda.evaluation.project.vo.BatchInfoNameVO;
import com.slofzx.nuoda.evaluation.project.vo.PlanInfoVO;
import com.slofzx.nuoda.common.enums.ServiceResult;
import org.springframework.http.ResponseEntity;

import javax.servlet.http.HttpServletRequest;
import java.util.List;

/**
 * 评价方案基本信息表(PlanInfo)表服务接口
 *
 * @author nuoda
 * @since 2024-03-15 09:21:37
 */
public interface PlanInfoService {

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    PlanInfoVO queryById(String id);

    /**
     * 查询多条数据
     *
     * @param dto 数据传递类实例对象
     * @return 对象列表
     */
    List<PlanInfoVO> queryList(PlanInfoDTO dto);

    /**
     * 新增数据
     *
     * @param dto 数据传递类实例对象
     * @return 操作结果
     */
    ServiceResult create(PlanInfoDTO dto);

    /**
     * 修改数据
     *
     * @param dto 数据传递类实例对象
     * @return 操作结果
     */
    ServiceResult update(PlanInfoDTO dto);
    /**
     * 锁定数据
     *
     * @param dto 数据传递类实例对象
     * @return 操作结果
     */
    ServiceResult lock(PlanInfoDTO dto);
    /**
     * 解锁数据
     *
     * @param dto 数据传递类实例对象
     * @return 操作结果
     */
    ServiceResult unlock(PlanInfoDTO dto);

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 操作结果
     */
    ServiceResult deleteById(String id);

    List<BatchInfoNameVO> queryNameList();

    ServiceResult editCommonData(PlanInfoDTO dto);

    ServiceResult importExcel(String fileId, String batchId);

    ResponseEntity<byte[]> exportExcel(HttpServletRequest request, ProjectInfoDTO projectInfoDTO);
}
